我想从数组中随机选取一个元素,将其从数组中移除,然后返回该元素。我可以使用sample获取一个元素,使用index找到它的位置,然后使用delete_at删除它,但是是否存在有更好的方法吗? 最佳答案 array.delete_at(rand(array.length))这似乎是正确的,我想它效果最好。编辑:同样的答案在这里:Isthereaparticularfunctiontoretrievethendeleterandomarrayelement?所以我会选择这个:D 关于ruby
我有一个名为MentorData的Rails模型,它有一个名为os_usage的属性。这些ose存储在一个数组中,就像这样['apple','linux']。回顾一下:$MentorData.first.os_usage=>['apple','linux']我希望能够查询所有MentorData的数据,包括apple的os_usage,但是当我搜索MentorData.where(os_usage:'apple')我只得到只会用apple不会用apple和linux的导师。我需要以某种方式进行搜索以检查苹果是否包含在数组中。我也试过以下方法。MentorData.where('os_u
我们可以使用Array的zip方法同时迭代两个数组,例如:@budget.zip(@actual).eachdo|budget,actual|...end是否可以迭代三个数组?我们可以使用transpose方法来做同样的事情吗? 最佳答案 >>[1,2,3].zip(["a","b","c"],[:a,:b,:c]){|x,y,z|p[x,y,z]}[1,"a",:a][2,"b",:b][3,"c",:c]transpose也可以,但与zip不同的是,它会立即创建一个新数组:>>[[1,2,3],["a","b","c"],[:a
我有一个充满对象的json数组。my_array=[{id=>6,name=>"bob"},{id=>5,name=>"jim"},{id=>2,name=>"steve"}]我需要查看数组是否包含一个对象,该对象包含设置为5的属性“id”。“name”属性未知。我如何在rspec中执行此操作?我知道如果我有name属性我知道我可以这样做:my_array.shouldinclude({:id=>5,:name=>"jim"}) 最佳答案 expect(myArray.find{|item|item[:id]==5}).to_not
我在弄清楚如何对数组的数组进行排序时遇到问题。两个数组都很简单,我相信它很简单,但我似乎无法弄明白。这是数组:[["happy",1],["sad",2],["mad",1],["bad",3],["glad",12]]我想按内部数组的整数值对它进行排序,该整数值是单词出现次数的值,最大的在前。 最佳答案 试试:array=[["happy",1],["sad",2],["mad",1],["bad",3],["glad",12]]sorted=array.sort{|a,b|a[1]b[1]}或者:array=[["happy",
我认为这是一个多选复选框型号classUser:destroyaccepts_nested_attributes_for:user_roles,:allow_destroy=>truehas_many:roles,:through=>:user_rolesend查看强参数写成defuserparams.require(:user).permit(:first_name,{:role_ids=>[]})end但是在创建时它说ProcessingbyAdmin::UsersController#createasHTMLParameters:{"utf8"=>"✓","authenticit
我有一个数组@words=Word.find_all_by_lesson_id(params[:id])-@user.words并且想通过word_id找到一个元素,比如@current_word=@words[params[:id2].to_i]在哪里params[:id2]是words.id当然错了,因为数组索引和words.id不一样,那我该怎么做才能正确呢?或如果我想从模型中排除一些记录,你能建议我如何使用该模型吗? 最佳答案 @current_word=@words.detect{|w|w.id==params[:id2]
我有一个包含独特元素的数组。有没有办法在不使用其索引值的情况下将其中的某个值替换为另一个值?例子:array=[1,2,3,4]ifarray.include?4#"replace4with'Z'"endarray#=>[1,2,3,'Z']hash={"One"=>[1,2,3,4]}ifhash["One"].include?4#"replace4with'Z'"endhash#=>{"One"=>[1,2,3,'Z']} 最佳答案 parray.map{|x|x==4?'Z':x}#=>[1,2,3,'Z']
这个问题在这里已经有了答案:Strange,unexpectedbehavior(disappearing/changingvalues)whenusingHashdefaultvalue,e.g.Hash.new([])(4个答案)关闭7年前。我尝试了以下ruby代码,我认为它会将单词长度的散列返回到具有这些长度的单词。相反,它是空的。map=Hash.new(Array.new)strings=["abc","def","four","five"]strings.eachdo|word|map[word.length]但是,如果我将其修改为map=Hash.newstrings
我想转这个字符串"P07091MMCNEFFEGP06870IVGGWECEQHSSP0A8M0VVPVADVLQGRP01019VIHNESTCEQ"变成一个看起来像ruby的数组。["P07091MMCNEFFEG","P06870IVGGWECEQHS","SP0A8M0VVPVADVLQGR","P01019VIHNESTCEQ"]由于换行,使用split没有返回我想要的结果。 最佳答案 这是处理空行的一种方式:string.split(/\n+/)例如,string="P07091MMCNEFFEGP06870IVGG